<?php
//
// +----------------------------------------------------------------------+
// |zen-cart Open Source E-commerce                                       |
// +----------------------------------------------------------------------+
// | Copyright (c) 2003 The zen-cart developers                           |
// |                                                                      |   
// | http://www.zen-cart.com/index.php                                    |   
// |                                                                      |   
// | Portions Copyright (c) 2003 osCommerce                               |
// +----------------------------------------------------------------------+
// | This source file is subject to version 2.0 of the GPL license,       |
// | that is bundled with this package in the file LICENSE, and is        |
// | available through the world-wide-web at the following url:           |
// | http://www.zen-cart.com/license/2_0.txt.                             |
// | If you did not receive a copy of the zen-cart license and are unable |
// | to obtain it through the world-wide-web, please send a note to       |
// | license@zen-cart.com so we can mail you a copy immediately.          |
// +----------------------------------------------------------------------+
// $Id: DIRECTBANK.php 1105 2006-06-06 22:05:35Z OZ_jack $ modify from Auzbank of OZcommerce module by birdbrain
//

  class directbank {
    var $code, $title, $description, $enabled;

// class constructor
    function directbank() {
      global $order;

      $this->code = 'directbank';
      $this->title = MODULE_PAYMENT_DIRECTBANK_TEXT_TITLE;
      $this->description = MODULE_PAYMENT_DIRECTBANK_TEXT_DESCRIPTION;
      $this->email_footer = MODULE_PAYMENT_DIRECTBANK_TEXT_EMAIL_FOOTER;
      $this->sort_order = MODULE_PAYMENT_DIRECTBANK_SORT_ORDER;
      $this->enabled = ((MODULE_PAYMENT_DIRECTBANK_STATUS == 'True') ? true : false);

      if ((int)MODULE_PAYMENT_DIRECTBANK_ORDER_STATUS_ID > 0) {
        $this->order_status = MODULE_PAYMENT_DIRECTBANK_ORDER_STATUS_ID;
      }

      if (is_object($order)) $this->update_status();
    }

// class methods
    function update_status() {
      global $order, $db;

      if ( ($this->enabled == true) && ((int)MODULE_PAYMENT_DIRECTBANK_ZONE > 0) ) {
        $check_flag = false;
        $check = $db->Execute("select zone_id from " . TABLE_ZONES_TO_GEO_ZONES . " where geo_zone_id = '" . MODULE_PAYMENT_DIRECTBANK_ZONE . "' and zone_country_id = '" . $order->delivery['country']['id'] . "' order by zone_id");
        while (!$check->EOF) {
          if ($check->fields['zone_id'] < 1) {
            $check_flag = true;
            break;
          } elseif ($check->fields['zone_id'] == $order->delivery['zone_id']) {
            $check_flag = true;
            break;
          }
          $check->MoveNext();
        }

        if ($check_flag == false) {
          $this->enabled = false;
        }
      }
// disable the module if the order only contains virtual products
      if ($this->enabled == true) {
        if ($order->content_type == 'virtual') {
          $this->enabled = false;
        }
      }
    }

    function javascript_validation() {
      return false;
    }

    function selection() {
      return array('id' => $this->code,
                   'module' => $this->title);
    }

    function pre_confirmation_check() {
      return false;
    }

    function confirmation() {
      return array('title' => MODULE_PAYMENT_DIRECTBANK_TEXT_DESCRIPTION);
    }

    function process_button() {
      return false;
    }

    function before_process() {
      return false;
    }

    function after_process() {
      return false;
    }

    function get_error() {
      return false;
    }

    function check() {
      global $db;
      if (!isset($this->_check)) {
        $check_query = $db->Execute("select configuration_value from " . TABLE_CONFIGURATION . " where configuration_key = 'MODULE_PAYMENT_DIRECTBANK_STATUS'");
        $this->_check = $check_query->RecordCount();
      }
      return $this->_check;
    }

    function install() {
      global $db;
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, set_function, date_added) values ('Enable Direct Bank Account/ Visa Card/ Master Card Transfer Module', 'MODULE_PAYMENT_DIRECTBANK_STATUS', 'True', 'Do you want to accept Australian Bank Deposit payments?', '6', '1', 'zen_cfg_select_option(array(\'True\', \'False\'), ', now())");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, use_function, set_function, date_added) values ('Payment Zone', 'MODULE_PAYMENT_DIRECTBANK_ZONE', '0', 'If a zone is selected, only enable this payment method for that zone.', '6', '2', 'zen_get_zone_class_title', 'zen_cfg_pull_down_zone_classes(', now())");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Sort order of display.', 'MODULE_PAYMENT_DIRECTBANK_SORT_ORDER', '0', 'Sort order of display. Lowest is displayed first.', '6', '0', now())");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('VISA Number', 'MODULE_PAYMENT_DIRECTBANK_VISA', '00-00-00', 'VISA Number in the format 000-000', '6', '1', now());");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Bank Account No.', 'MODULE_PAYMENT_DIRECTBANK_ACCNUM', '12345678', 'Bank Account No.', '6', '1', now());");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('MASTERCARD Number.', 'MODULE_PAYMENT_DIRECTBANK_MASTER', '12345678', 'MASTERCARD Number.', '6', '1', now());");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Bank Account Name', 'MODULE_PAYMENT_DIRECTBANK_ACCNAM', 'Joe Bloggs', 'Bank account name', '6', '1', now());");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Bank Name', 'MODULE_PAYMENT_DIRECTBANK_BANKNAM', 'The Bank', 'Bank Name', '6', '1', now());");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added)
values ('VISA Number1', 'MODULE_PAYMENT_DIRECTBANK_VISA1', '00-00-00', 'VISA Number in the format 000-000', '6', '1', now());");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Bank Account No.', 'MODULE_PAYMENT_DIRECTBANK_ACCNUM1', '12345678', 'Bank Account No.', '6', '1', now());");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('MASTERCARD Number.', 'MODULE_PAYMENT_DIRECTBANK_MASTER1', '12345678', 'MASTERCARD Number.', '6', '1', now());");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Bank Account Name', 'MODULE_PAYMENT_DIRECTBANK_ACCNAM1', 'Joe Bloggs', 'Bank account name', '6', '1', now());");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Bank Name', 'MODULE_PAYMENT_DIRECTBANK_BANKNAM1', 'The Bank', 'Bank Name', '6', '1', now());");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added)
values ('VISA Number1', 'MODULE_PAYMENT_DIRECTBANK_VISA2', '00-00-00', 'VISA Number in the format 000-000', '6', '1', now());");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Bank Account No.', 'MODULE_PAYMENT_DIRECTBANK_ACCNUM2', '12345678', 'Bank Account No.', '6', '1', now());");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('MASTERCARD Number.', 'MODULE_PAYMENT_DIRECTBANK_MASTER2', '12345678', 'MASTERCARD Number.', '6', '1', now());");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Bank Account Name', 'MODULE_PAYMENT_DIRECTBANK_ACCNAM2', 'Joe Bloggs', 'Bank account name', '6', '1', now());");
     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Bank Name', 'MODULE_PAYMENT_DIRECTBANK_BANKNAM2', 'The Bank', 'Bank Name', '6', '1', now());");

     $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, set_function, use_function, date_added) values ('Set Order Status', 'MODULE_PAYMENT_DIRECTBANK_ORDER_STATUS_ID', '0', 'Set the status of orders made with this payment module to this value', '6', '0', 'zen_cfg_pull_down_order_statuses(', 'zen_get_order_status_name', now())");
   }

    function remove() {
      global $db;
      $db->Execute("delete from " . TABLE_CONFIGURATION . " where configuration_key in ('" . implode("', '", $this->keys()) . "')");
    }

    function keys() {
	  return array('MODULE_PAYMENT_DIRECTBANK_STATUS', 'MODULE_PAYMENT_DIRECTBANK_ZONE', 'MODULE_PAYMENT_DIRECTBANK_SORT_ORDER', 'MODULE_PAYMENT_DIRECTBANK_VISA', 'MODULE_PAYMENT_DIRECTBANK_ACCNUM', 'MODULE_PAYMENT_DIRECTBANK_ACCNAM', 'MODULE_PAYMENT_DIRECTBANK_MASTER', 'MODULE_PAYMENT_DIRECTBANK_BANKNAM', 'MODULE_PAYMENT_DIRECTBANK_VISA1', 'MODULE_PAYMENT_DIRECTBANK_ACCNUM1', 'MODULE_PAYMENT_DIRECTBANK_ACCNAM1', 'MODULE_PAYMENT_DIRECTBANK_MASTER1', 'MODULE_PAYMENT_DIRECTBANK_BANKNAM1', 'MODULE_PAYMENT_DIRECTBANK_VISA2', 'MODULE_PAYMENT_DIRECTBANK_ACCNUM2', 'MODULE_PAYMENT_DIRECTBANK_ACCNAM2', 'MODULE_PAYMENT_DIRECTBANK_MASTER2', 'MODULE_PAYMENT_DIRECTBANK_BANKNAM2', 'MODULE_PAYMENT_DIRECTBANK_ORDER_STATUS_ID');
    }
  }
?>
